home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Programming Languages Suite
/
ProgramD2.iso
/
Borland
/
Borland C++ V5.02
/
32SNIPIT.PAK
/
INMEMTBL.C
< prev
next >
Wrap
C/C++ Source or Header
|
1997-05-06
|
7KB
|
197 lines
// BDE32 3.x - (C) Copyright 1996 by Borland International
// Inmemtbl.C
#include "snipit.h"
static char szTblName[] = "INMEMTBL";
// Field Descriptor used in creating a table
static SNIPFAR FLDDesc fldDesc[] = {
{ // Field 1 - ALPHA
1, // Field number
"ALPHA", // Field name
fldZSTRING, // Field type
fldUNKNOWN, // Field subtype
10, // Field size
0, // Decimal places ( 0 )
// computed
0, // Offset in record ( 0 )
11, // Length in bytes ( 0 )
0, // For Null bits ( 0 )
fldvNOCHECKS, // Validity checks ( 0 )
fldrREADWRITE // Rights
},
{ // Field 2 - NUMERIC
2, "NUMERIC", fldFLOAT, fldUNKNOWN,
0, 0, 0, 8, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 3 - MONEY
3, "MONEY", fldFLOAT, fldstMONEY,
0, 0, 0, 8, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 4 - DATE
4, "DATE", fldDATE, fldUNKNOWN,
0, 0, 0, 4, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 5 - SHORT
5, "SHORT", fldINT16, fldUNKNOWN,
0, 0, 0, 2, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 6 - TIME
6, "TIME", fldTIME, fldUNKNOWN,
0, 0, 0, 4, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 7 - TIMESTAMP
7, "TIMESTAMP", fldTIMESTAMP, fldUNKNOWN,
0, 0, 0, 8, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 8 - LONG
8, "LONG", fldINT32, fldUNKNOWN,
0, 0, 0, 4, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 9 - BOOL
9, "BOOL", fldBOOL, fldUNKNOWN,
0, 0, 0, 2, 0, fldvNOCHECKS, fldrREADWRITE
},
{ // Field 10 - BYTES
10, "BYTES", fldBYTES, fldUNKNOWN,
20, 0, 0, 20, 0, fldvNOCHECKS, fldrREADWRITE
}
}; // Array of field descriptors
// The number of fields in the table
static UINT16 uNumFields = sizeof(fldDesc) / sizeof (fldDesc[0]);
static DBIResult FillTable1(hDBICur hCur, FLOAT NumRecs);
//=====================================================================
// Function:
//
// CreateAndFillInMemoryTbl();
// Description:
// This sample code will create an in-memory table, insert
// 10 records into the table, then close the table.
//
// There are the following limits for In-Memory table:
// Fields: 1024
// Max Rec Size: 16K
// Indexes: 0 (Cannot be indexed)
// Table Size: 512M
//=====================================================================
void
CreateAndFillInMemoryTbl (void)
{
hDBIDb hDb; // Handle to the database
hDBICur hCur; // Handle to the table
UINT16 uDispNumRecs = 10 ; // Number of records to add and
// display.
DBIResult rslt; // Return value from IDAPI functions
Screen("*** Create/Open/Fill In-Memory Example ***\r\n");
BREAK_IN_DEBUGGER();
Screen(" Initializing IDAPI...");
if (InitAndConnect(&hDb) != DBIERR_NONE)
{
Screen("\r\n*** End of Example ***");
return;
}
Screen(" Setting the database directory...");
rslt = DbiSetDirectory(hDb, (pCHAR) szTblDirectory);
ChkRslt(rslt, "SetDirectory");
Screen(" Creating the %s in-memory table...", szTblName);
rslt = DbiCreateInMemTable(hDb, szTblName, uNumFields, fldDesc, &hCur);
if (ChkRslt(rslt, "CreateTable") != DBIERR_NONE)
{
CloseDbAndExit(&hDb);
Screen("\r\n*** End of Example ***");
return;
}
Screen(" Fill the %s table with random data...", szTblName);
FillTable1(hCur, uDispNumRecs);
rslt = DbiSetToBegin(hCur);
ChkRslt(rslt, "SetToBegin");
Screen(" Display the %s table which we just created...", szTblName);
DisplayInMemoryTable(hCur, uDispNumRecs);
// You do not need to delete this table. IDAPI will delete the
// table when it is closed.
Screen("\r\n Close the %s table...", szTblName);
rslt = DbiCloseCursor(&hCur);
ChkRslt(rslt, "CloseCursor");
Screen(" Close the database and exit IDAPI...");
CloseDbAndExit(&hDb);
Screen("\r\n*** End of Example ***");
}
//=====================================================================
// Function:
// FillTable1(hCur, NumRecs);
//
// Input: hCur - The table cursor
// NumRecs - The number of records to insert
//
// Return: DBIResult - success?
//
// Description:
// This function adds the specified number of records to
// the in-memory table.
//=====================================================================
DBIResult
FillTable1 (hDBICur hCur, FLOAT NumRecs)
{
DBIResult rslt; // Return value from IDAPI functions
FLOAT fRecCount; // Loop variable = count of records
UINT16 FldCntr; // Field counter
pBYTE pRecBuf; // Pointer to the record buffer
CURProps TblProps; // Table descriptor
Screen(" Inserting %.0f records into the table...", NumRecs);
if (hCur)
{
// Allocate a record buffer
rslt = DbiGetCursorProps(hCur, &TblProps);
ChkRslt(rslt, "GetCursorProps");
pRecBuf = (pBYTE) malloc(TblProps.iRecBufSize);
if (pRecBuf == NULL)
{
Screen(" Error - Out of memory");
return DBIERR_NOMEMORY;
}
// Loop until the specified number of records have been written
// to the table.
for (fRecCount = 0; fRecCount < NumRecs; fRecCount++)
{
// Make sure we're starting with a clean record buffer
rslt = DbiInitRecord(hCur, pRecBuf);
ChkRslt(rslt, "InitRecord");
for (FldCntr = 0; FldCntr < uNumFields; FldCntr++)
{
// Put field data into the record buffer
PutFieldSample(hCur, pRecBuf, (UINT16)(FldCntr + 1), &fldDesc[FldCntr]);
}
// Append the record to the table...
rslt = DbiAppendRecord(hCur, pRecBuf);
ChkRslt(rslt, "InsertRecord");
}
free((pCHAR) pRecBuf);
}
return DBIERR_NONE;
}